<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script src="./js/vue.js"></script>
    <title>嵌套组件</title>
    <style>
        
    </style>
</head>
<body>
    <div id="root">
        <!-- 
        -->
        <!-- 第三步 使用组件 -->
        <!-- <app></app> -->
    </div>
</body>
<script>

    //第一步 创建组件
    const app = Vue.extend({
        template: `
            <div>
                <hello></hello>
                <school></school>
            </div>`
        
    })

    //第一步 创建组件
    const student = Vue.extend({
        template: `
            <div>
                <h1>学生姓名:{{studentName}}</h1>
                <h1>学生年龄:{{studentAge}}</h1>
                
            </div>`,
        data() {
            return {
                studentName: "张三",    // 学生姓名
                studentAge: 20  // 学生年龄
            }
        }
    })
    //第一步 创建组件
    const school = Vue.extend({
        template: `
            <div>
                <h1>学校名称:{{schoolName}}</h1>
                <h1>学校地址:{{address}}</h1>
                <button @click="showSchoolName">点我显示学校名称</button>
                <student></student>
            </div>`,
        data() {
            return {
                schoolName: "尚硅谷",    // 学校名称
                address: "北京市海淀区西二旗"  // 学校地址
            }
        },
        methods: {
            showSchoolName() {
                alert(this.schoolName);
            }
        },
        components: {
            "student": student
        }
    })

    

    //第一步 创建组件
    const hello = Vue.extend({
        template: `
            <div>
                <h1>你好啊{{name}}</h1>
            </div>`,
        data() {
            return {
                name: "张三"
            }
        }
    })



    // 第二步，注册组件(全局注册)
    Vue.component("hello", hello);
    Vue.component("school", school);
   
    var vm = new Vue({
        template: `
                <app></app>
            `,
        el: '#root',
        // 第二步，注册组件(局部注册)
        components: {
            "app": app
        }
    })
   
</script>
</html>